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FIG. 3 



RECEIVE CREDIT PACKET 



LAST FCC 


Ln=FCCL 






ABRn=FCTBS 
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FIG. 4 



DUMP ARRIVING PACKET 



SET CREDIT EXCEEDED 
BIT IN CAUSE REGISTER 



RECEIVE DATA PACKET 
X=[PACKET LENGTH/16] 




ABR=(ABR+X) 



YES 



(X^GLOBAL. 
SPARE_CRED) 
AND (X+SPARE_CREDn)« 
MAX_SPARE_CREDn 



GLOBAL_SPARE_CRED-=X 
SPARE_CREDn+=X 



NO 



FREE CREDn-=X 




txq_fccln[ll:0]= 
(ABRN+FREE_CREDn) 
%4096 



txq_fccln[ll:0]= 
(ABRN+2048)%4096 
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FIG. 5 



SEND DATA PACKET 
FROM RxQ OF LANE n 



ANY 

LANES OCCUPYING 
CREDITS IN STATIC 
AREA? 



YES 



NO 







SPARE_CREDn-=X 
GLOBAL_SPARE_CRED+=X 




FREE_CREDn+=X 



SPARE_CREDn — 



NEXT LANE m OCCUPYING 
CREDITS IN BOTH STATIC 
AND DYNAMIC AREAS 



FREE_CREDm ++ 
SPARE_CREDm ++ 



NEXT CREDIT UP TO X 



